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Apparatus, Method and Computer Program 
Product for Efficiently Pooling Connections 
Between Clients and Servers 



Inventors: Michel K. Susai 
Rajiv Sinha 
Anil Shetty 

Cross-Reference to Related Applications 

The present application is related to U.S. Patent Application No. 
09/188,709, filed November 10, 1998, entitled, "Internet Client-Server 
Multiplexer" (incorporated by reference in its entirety). 

Background of the Invention 

Field of the Invention 

The present invention relates generally to Internet client-server 
applications, and more specifically to determining when a client is finished, either 
temporarily (e.g., in "think time") or permanently, with a connection in order to 
more efficiently utilize the pooling of connections between clients and servers 
over the Internet. 

RelatedArt 

The importance to the modern economy of rapid information and data 
exchange cannot be overstated. This explains the exponentially increasing 
popularity of the Internet. The Internet is a world-wide set of interconnected 
computer networks that can be used to access a growing amount and variety of 
information electronically. 

One method of accessing information on the Internet is known as the 
World Wide Web (www, or the "web"). The web is a distributed, hypermedia 
system, and functions as a client-server based information presentation system. 
Information that is intended to be accessible over the web is stored in the form of 
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"pages" on general-purpose computers known as "servers". Computer users can 
access a web page using general-purpose computers, referred to as "clients," by 
specifying the uniform resource locator (URL) of the page. FIG. 1 is a network 
block diagram showing a plurality of clients and servers connected to the Internet. 

When a client specifies a URL, a part of the URL known as the Domain 
Name is passed to a domain server (DNS) to be translated to a network address. 
The network address specifies the Internet protocol (IP) address of the intended 
server. The client request is passed to the server having the network address. 
The server uses the path name in the URL to locate the web page requested by the 
client. A copy of the web page is then sent to the client for viewing by the user. 

The client-server paradigm described above has served the Internet well. 
However, there are some problems. One problem called server connection 
loading was described in detail in the commonly-owned, U.S. Patent Application 
No. 09/188,709, filed November 10, 1998, entitled, "Internet Client-Server 
Multiplexer," incorporated herein by reference in its entirety. For completeness, 
however, the connection loading problem is briefly described herein. 

Servers are designed to do certain things well. Servers are typically 
general-purpose machines that are optimized for general tasks such as file 
management, application processing, database processing, and the like. Servers 
are not optimized to handle switching tasks such as opening and closing network 
connections. Under certain load conditions, these tasks can represent a 
considerable overhead, consuming a large percentage of the server's processing 
resources, often on the order of twenty percent and sometimes up to fifty percent. 
This problem is referred to herein as "connection loading". 

To further explain loading, the client and server must typically exchange 
three packets of information to setup a connection. Once the connection is 
established a client sends a URL (page) request to the server, this consists of one 
or more packets. The server will then send one or more packet responses back 
to the client. Once a request and response is exchanged from the client and 
server, both client and server will close their respective connections. The closing 
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of the connection takes an additional four packets of information exchange. As 
demonstrated above, there is a significant amount of overhead (i.e., seven 
packets) involved to download one URL. A page typically consists of multiple 
URL's. 

5 Additional problems associated with connection loading include: 

Each packet that reaches the server interrupts the server's CPU to move 
that packet from the Network Interface Card (NIC) into the server's main 
memory. This results in loss of productivity on the server's CPU. Thus what 
is needed is a way to avoid wasting valuable CPU time at the server side. As a 

10 consequence, the same resource can be applied to process more URL (page) 

requests. This will thus improve the servers URL processing capacity. 

As discussed above, it takes three packets for connection establishment. 
Furthermore, connection establishment uses up significant server resources 
related to the CPU/memory. To establish a connection at the server side, the 

15 packet needs to be processed by the driver layer, where Ethernet specific 

information is handled. The driver layer sends the packet to the IP (Internet 
Protocol) layer for more processing, where all the IP related processing is 
handled. After this, the packet is passed to TCP (Transmission Control Protocol) 
layer, where the TCP related information is processed. The TCP layer consumes 

20 significant server resources to create a connection table, etc. Thus, what is 

needed is a way of avoiding connection processing to thereby save significant 
CPU/memory resources. 

The Web server needs to create a thread for each incoming connection to 
be processed. After the connection and URL request are processed, the thread 

25 will be closed. A thread is a Light Weight Process (LWP) that is a type of 

process. Even though threads are efficient it takes significant CPU and memory 
resources to create and destroy the threads. Thus, by avoiding thread creation, a 
significant amount of server resources can be preserved, which in turn can be 
used to process more web requests. 
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It is desirable to efficiently solve the connection loading problem by 
determining when a client is either through with a connection or idle for some 
period of time in order to more efficiently utilize the pooling of connections 
between clients and servers over the Internet. 



5 Summary of the Invention 

The present invention is an apparatus, method and computer program 
product for efficiently pooling network client-server connections. In one 
embodiment, the present invention is implemented within an interface unit 
connecting a plurality of servers to the Internet, which is in turn connected to a 

10 plurality of clients. 

According to one aspect of the invention, the method includes the steps 
of opening a connection between a first client and the interface unit; determining 
whether a connection between the interface unit and a server is finished being 
utilized by the first client; opening a connection between a second client and the 

15 interface unit; if no free connection is open between the interface unit and the 

server, then allowing the second client to access information on the server via the 
same connection utilized by the first client without waiting for the first client to 
initiate closing the connection; and delinking the connections between the first 
and second clients and the interface unit while keeping open the connection 

20 between the interface unit and the server. 
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Brief Description of the Figures 

The features and advantages of the present invention will become more 
apparent from the detailed description set forth below when taken in conjunction 
with the drawings in which like reference characters identify corresponding 
elements throughout and wherein: 

FIG. 1 is a network block diagram showing a plurality of clients and 
servers connected to the Internet according to an embodiment of the present 
invention; 

FIG. 2 is a network context diagram for an interface unit according to an 
embodiment of the present invention; 

FIG. 3 is a flowchart illustrating the operation of the connection pooling 
aspect of the present invention according to an embodiment of the present 
invention; 

FIG. 4 is a flowchart depicting the operation of the present invention in 
translating client and server requests according to an embodiment of the present 
invention; 

FIG. 5 illustrates a content length parameter according to an embodiment 
of the present invention. 

FIG. 6 illustrates chunk-size fields according to an embodiment of the 
present invention. 

FIG. 7 is a message flow diagram illustrating the connection pooling 
aspect of the present invention according to an embodiment of the present 
invention; 

FIG. 8 is a detailed flow diagram illustrating the use of the content length 
parameter to increase the efficiency of the pooling of connections between clients 
and servers according to an embodiment of the present invention; 

FIG. 9 is a flowchart depicting the operation of the use of the content 
length parameter to increase the efficiency of the pooling of connections between 
clients and servers according to an embodiment of the present invention; 
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FIG. 1 0 is a detailed flow diagram illustrating the use of chunk-size fields 
to increase the efficiency of the pooling of connections between clients and 
servers according to an embodiment of the present invention; 

FIG. His a flowchart depicting the operation of the use of chunk-size 
5 fields to increase the efficiency of the pooling of connections between clients and 

servers according to an embodiment of the present invention; and 

FIG. 12 depicts an example computer system in which the present 
invention can be implemented according to an embodiment of the present 
invention. 



Detailed Description of the Preferred Embodiments 

The present invention is an apparatus, method and computer program 
product for efficient network client-server connection pooling. 

FIG. 2 is a network context diagram for interface unit 202 according to 
an embodiment of the present invention. In this embodiment, an interface unit 
is an intelligent network interface card with a CPU inside a server. An interface 
unit can also be an intelligent box sitting outside the server, in which case it can 
serve more than one server. Interface unit 202 can also be a load balancer, 
bandwidth manager, firewall, router, switch, computer system, or any other 
network device that is located between a client and server. 

Referring to FIG. 2, a plurality of clients CI, C2, C3 are coupled to the 
Internet and a plurality of servers SI, S2, S3, are coupled to the Internet by 
interface unit 202. Servers SI, S2, S3 are collectively referred to as a "server 
farm". All Internet traffic with the server farm passes through interface unit 202. 
While the present invention is described in terms of the Internet, the concepts 
described also apply to other types of networks, as will be apparent to one skilled 
in the relevant art. 

As described in detail in the commonly-owned, U.S. Patent Application 
No. 09/188,709, filed November 10, 1998, entitled, "Internet Client-Server 
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Multiplexer," interface unit 202 relieves servers SI, S2, S3 of much of the 
processing load caused by repeatedly opening and closing connections to clients 
by opening one or more connections with each server and maintaining these 
connections to allow repeated data accesses by clients via the Internet. This 
5 technique is referred to herein as "connection pooling". 

For completeness, the operation of connection pooling is briefly described 
next with reference to FIG. 3. The process begins in FIG. 3 when a client 
requests access to one of the servers in the server farm tended by interface unit 
202. A connection is opened between interface unit 202 and the requesting client, 

10 and interface unit 202 receives the client request to access the server, as shown 

in step 302. Interface unit 202 determines the identity of the requested server as 
shown in step 304. In one embodiment, this is accomplished by examining the 
destination network address specified by the client request. In another 
embodiment, this is accomplished by examining the network address and path 

15 name specified by the client request. 

After determining the identity of the server to which the client request 
should be directed, interface unit 202 determines whether a free connection (that 
is, one that is not in use) to the server is already open, as shown in step 306. If 
so, processing resumes at step 310. If not, interface unit 202 opens a connection 

20 to the server, as shown in step 308. Interface unit 202 then translates the client 

request and passes it to the server, as shown in step 310, and as more fully 
described with respect to FIG. 4, below. After server processing, interface unit 
receives a response from the server, as shown in step 312. The server response 
is translated and passed to the requesting client, as shown in step 314 and 

25 described further below. Finally, interface unit 202 closes the connection with 

the client as shown in step 3 1 6. However, the connection between interface unit 
202 and server is not disconnected. By maintaining open connections with the 
servers and by opening and closing connections with the client as needed, 
interface unit 202 frees the servers of nearly all of the connection loading 

30 problems associated with serving clients over the Internet. 
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As will be discussed further below, the present invention is related to step 
316, where interface unit 202 closes the connection with the client. There are a 
number of scenarios that result in interface unit 202 closing the connection with 
the client. For example, the client may initiate a FIN (finish) command or a RST 
5 (reset) command. In both of these scenarios, interface unit 202 waits until it 

receives one of these commands before it loses the connection between itself and 
the client. Inefficiencies with connection pooling occur when the client is not 
using or finished with the connection but does not relay this information to 
interface unit 202 for a period of time. Because interface unit 202 is waiting for 

10 a command from the client in order to reuse the connection for another client, the 

connection is tied up unnecessarily. 

As will be explained in more detail below, Hyper-Text Transfer Protocol 
(HTTP) 1.1 (by default) and HTTP 1.0 (with the Connection: Keep- Alive 
Technique, as described in detail in U.S. Patent Application No. 09/188,709) 

15 enable the client and/or interface unit 202 to keep the connection open with the 

server even after receiving a server response to a request. The client and/or 
interface unit 202 may then issue other requests via the same connection, either 
immediately or after considerable time (or "think time"). A client is in "think 
time" when the human operator of the client is deciding the next link on the 

20 browser to click, and so forth. This can result in connections being maintained 

by the server even though the server is not processing any requests via the 
connections. Here, server administrators may be forced to guard against too 
many simultaneous connections on the server by setting a Keep- Alive timeout 
after which the connection which has been idle or in "think time" is closed. The 

25 present invention allows the connection to the server to be used by client 2 while 

the client 1 is "thinking". Of course, if client 2 makes a request when client 1 is 
using the server connection, then client 2 must use a different connection to the 
server. However, the efficiency of the connection pooling of the present 
invention is realized when a very small number of connections is exceeded and 

30 moves into the general case. The general case being when 'n' client connections 
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may be statistically multiplexed onto 'm' server connections, where 'n' is greater 
than 'm' . 

FIG. 4 is a flowchart depicting the operation of the present invention in 
translating client and server requests, as shown in steps 310 and 314 (FIG. 3). In 
an embodiment, the message traffic is in the form of TCP/IP packets, a protocol 
suite that is well-known in the art. The TCP/IP protocol suite supports many 
applications, such as Telnet, File Transfer Protocol (FTP), e-mail, and HTTP. 
The present invention is described in terms of the HTTP protocol. However, the 
concepts of the present invention apply equally well to other TCP/IP applications, 
as will be apparent to one skilled in the art after reading this specification. 

Each TCP packet includes a TCP header and an IP header. The IP header 
includes a 32-bit source IP address and a 32-bit destination IP address. The TCP 
header includes a 1 6-bit source port number and a 1 6-bit destination port number. 
The source IP address and port number, collectively referred to as the source 
network address, uniquely identify the source interface of the packet. Likewise, 
the destination IP address and port number, collectively referred to as the 
destination network address, uniquely identify the destination interface for the 
packet. The source and destination network addresses of the packet uniquely 
identify a connection. The TCP header also includes a 32-bit sequence number 
and a 32-bit acknowledgment number. 

The TCP portion of the packet is referred to as a TCP segment. A TCP 
segment includes a TCP header and body. The body part of the TCP segment 
includes a HTTP header and the message. There are two mechanisms for 
determining the length of the message, including one based on chunked transfer 
encoding and another based on content-length. A content-length header file is 
found in the HTTP header. If a content-length header field is present, its value 
in bytes represents the length of the message-body. Alternatively, if a chunked 
transfer encoding header is present in the HTTP header, and indicates that the 
"chunked" transfer coding has been applied, then the length of the message is 
defined by the chunked encoding. The chunked encoding modifies the body of 
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a message in order to transfer the message as a series of chunks, each with its 
own indicator contained in the chunk-size field. 

As will be discussed in detail below, the present invention utilizes the 
content-length parameter and/or the chunked transfer encoding header to increase 
5 the efficiency of connection pooling between servers and clients by avoiding the 

situation where the client is in "think time". Without the present invention, 
interface unit 202 either waits for a command from the client before it reuses the 
connection for another client or the connection times out when the connection has 
been idle for too long. 

10 The 32-bit sequence number, mentioned above, identifies the byte in the 

string of data from the sending TCP to the receiving TCP that the first byte of 
data in the TCP segment represents. Since every byte that is exchanged is 
numbered, the acknowledgment number contains the next sequence number that 
the sender of the acknowledgment expects to receive. This is therefore the 

15 sequence number plus one of the last successfully received bytes of data. The 

checksum covers the TCP segment, i.e., the TCP header and the response data (or 
body). This is a mandatory field that must be calculated and stored by the sender, 
and then verified by the receiver. 

In order to successfully route an inbound packet from a client to the 

20 intended server, or to route an outbound packet from a server to a client, interface 

unit 202 employs a process known as "network address translation". Network 
address translation is well-known in the art, and is specified by request for 
comments (RFC) 1631, which can be found at the URL 
http://www.safetv.net/RFCl 63 1 .txt. 

25 However, in order to seamlessly splice the client and server connections, 

a novel translation technique was described in detail in the commonly-owned, 
U.S. Patent Application No. 09/188,709, filed November 10, 1998, entitled, 
"Internet Client-Server Multiplexer," referred to herein as "connection 
multiplexing". According to this technique, a packet is translated by modifying 

30 its sequence number and acknowledgment number at the TCP protocol level. A 
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significant advantage of this technique is that no application layer interaction is 
required. 

Referring to FIG. 4, the network address of the packet is translated, as 
shown in step 402. In the case of an in-bound packet (that is, a packet received 
from a client), the source network address of the packet is changed to that of an 
output port of interface unit 202, and the destination network address is changed 
to that of the intended server. In the case of an outbound packet (that is, one 
received from a server), the source network address is changed from that of the 
server to that of an output port of interface unit 202, and the destination address 
is changed from that of interface unit 202 to that of the requesting client. The 
sequence numbers and acknowledgment numbers of the packet are also 
translated, as shown in steps 404 and 406 and described in detail below. Finally, 
the packet checksum is recalculated to account for these translations, as shown 
in step 408. 

As mentioned above, the present invention is related specifically to an 
apparatus, method and computer program product for efficiently pooling network 
client-server connections though the content-length parameter and/or the 
chunked transfer encoding header to increase the efficiency of connection pooling 
between servers and clients. The increase in efficiency is the result of avoiding 
occupying the connection while the client is in "think time". In one embodiment 
of the present invention, the content length parameters is used to determine the 
length of the message. In another embodiment of the present invention, chunked 
transfer encoding is used to determine the length of the message. The two 
embodiments of the present invention will be described next with reference to 
FIGs. 5 and 6, respectively. 

FIG. 5 illustrates the TCP portion of a TCP packet called the TCP 
segment 500. The TCP segment 500 includes a TCP header 502 and a body 504. 
The body 504 contains, among other information, a HTTP header and the 
message. A content length parameter 506 is found in the HTTP header. How 
the present invention utilizes the content length parameter 506 to provide more 
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efficient connection pooling is described below with reference to FIGs. 8 and 9. 

FIG. 6 illustrates the TCP portion of a TCP packet called the TCP 
segment 600. As stated above, if a chunked transfer encoding header is present 
in the HTTP header, and indicates that the "chunked" transfer encoding has been 
5 applied, then the length of the message is defined by the chunked encoding. The 

chunked encoding modifies the body of a message in order to transfer the 
message as a series of chunks, each with its own indicator contained in the chunk- 
size field. The TCP segment 600 includes a TCP header (not shown) and a body. 
The body contains, among other information, a HTTP header 602 A-602C and the 

10 message. HTTP header 602A-602C is comprised of seven chunk-size fields 

606A-606G; and six chunk message data 604A-604F. 

The chunk-size fields 606A-606G are linked together, as illustrated in 
FIG. 6. The chunk-size field 606A indicates the length of the message in the 
chunk message data 604A, chunk-size field 606C indicates the length of the 

15 message in the chunk message data 604C, and so forth. The last chunk-size field 

606G always contains the length value zero indicating that there is no more 
message data to follow. This is an indication to the present invention that all of 
the message has been sent to the client. How the present invention utilizes the 
chunk-size fields 606A-606G to provide more efficient connection pooling is 

20 described below with reference to FIGs. 1 0 and 11. It is important to note that 

TCP segment 600 in FIG 6 is for illustration purposes only and does not limit the 
present invention. 

Prior to describing the detail of how the present invention utilizes the 
content length parameter to increase the efficiency of connection pooling, 

25 connection pooling as it is described in U.S . Patent Application No. 09/1 88,709, 

filed November 10, 1998, entitled, "Internet Client-Server Multiplexer," will first 
be discussed for completeness. FIG. 7 is a message flow diagram illustrating 
connection pooling. FIG. 7 shows interface unit 202 connecting two clients, CI 
and C2, to a server S. First, interface unit 202 opens a connection with client CI 

30 using network address 1 provided by client CI as shown by flow 702. Flow line 
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702 is shown as a two-way flow because the TCP/IP protocol employs a multi- 
stage handshake to open connections. 

Once the connection is opened, interface unit 202 receives a GET request 
from client CI specifying a path name of /sales/forecasthtml, as shown by flow 
5 line 704. Because no free connection is open between interface unit 202 and 

server S, interface unit 202 opens a connection with server S. Interface unit 202 
maps this request to network address 2, which specifies server S, as shown by 
flow line 706. Interface unit 202 also passes the GET request to that server, as 
shown by flow line 708. Server S responds with the requested web page, as 

10 shown by flow line 710. Interface unit 202 forwards the web page to client C 1 , 

as shown by flow line 712. Finally, the connection between client CI and 
interface unit 202 is closed, as shown by flow line 714. According to the TCP/IP 
protocol, closing a network connection can involve a multi-stage process. 
Therefore, flow line 714 is shown as bidirectional. It is important to note that 

15 interface unit 202 does not close the connection with server S, but rather keeps 

it open to accommodate further data flows. 

Next, a connection is opened between interface unit 202 and client C2 
using network address 1 provided by client C2, as shown by flow line 716. Next, 
interface unit 202 receives a GET request from client C2 specifying the Web page 

20 /sales/forecast.html, as shown by flow line 718. Because a free connection is 

already open between interface unit 202 and server S, it is unnecessary for 
interface unit 202 to burden server S with the processing load of opening a further 
connection. Interface unit 202 merely uses a free open connection. Interface unit 
202 maps the GET request to server S, transfers it, and forwards it to server S, as 

25 shown by flow line 720. Interface unit 202 receives the response from server S, 

as shown by flow line 722, and forwards it to client C2 as shown by flow line 
724. Finally, interface unit 202 closes the connection with client C2, as shown 
in flow line 726. Once again, interface unit 202 does not close the connection 
with server S. Instead, interface unit 202 keeps the connection open to 

30 accommodate further data flows. 



1763.0110000 



- 14- 



As discussed above, there are a number of scenarios that result in interface 
unit 202 closing the connection with client C2, as shown in flow line 724. For 
example, the client may initiate a FIN (finish) command, which occurs once the 
client has retrieved all requested data (or message). The client may also initiate 
a RST (reset) command. In addition to closing the connection between interface 
unit 202 and the client, the RST command results in a number of housekeeping 
operations being performed to keep the server side connection in good order. In 
particular, the TCP protocol guarantees that the RST command will have the right 
SEQ (sequence) number so that the server will accept the TCP segment; however, 
the RST command is not guaranteed to have the right ACK (acknowledge) 
number. To take care of this scenario, interface unit 202 keeps track of the bytes 
of data sent by the server and the bytes acknowledged by the client. If the client 
has not yet acknowledged all the data by the server, interface unit 202 calculates 
the unacknowledged bytes, and sends an ACK to the server. Furthermore, the 
server side PCB may be placed on a timeout queue to allow any pending server 
data transfers to drain. 

Furthermore, although not shown in FIG. 7, the server can also close a 
connection between itself and interface unit 202. The server would send a FIN 
command to interface unit 202. In this case, both the connection between the 
server and interface unit 202 and the connection between interface unit 202 and 
client will be closed. 

Another aspect of the invention is to maximize offload of connection 
processing from the server by minimizing the occasions on which the server 
closes the connection. There are three cases: 

(1) The protocol version HTTP/1 .1 is used. In this case, no explicit 
Keep- Alive header is required. By default, the server keeps the connection open; 
it is up to the client to close the connection. The present invention offloads the 
server by reusing the server side connection. Because it is up to the client to 
close the connection, inefficiencies with connection pooling occur when the client 
is finished with the connection but does not relay this information to interface 
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unit 202 for a period of time. Because interface unit 202 is waiting for a 
command from the client in order to reuse the connection for another client, the 
connection is tied up unnecessarily. 

(2) The protocol version HTTP/ 1.0 is used and the "Connection: 
5 Keep-Alive" header is provided by the client. In this case, the server keeps the 

connection open; it is up to the client to close the connection. The present 
invention offloads the server by reusing the server side connection. As with 
protocol version HTTP/1 . 1 , inefficiencies with connection pooling occur when 
the client is finished with the connection but does not relay this information to 
10 interface unit 202 for a period of time. 

(3) The protocol version HTTP/1.0 is used and the "Connection: 
Keep-Alive" header is not provided by the client. In this case, the server will 
normally (without the present invention) close the connection after fully 
satisfying one GET request. If the server closes the connection after each request 

15 this denies that interface unit 202 the opportunity to reuse the server side 

connection. As it turns out much of the Internet still uses HTTP/ 1.0 without 
"Connection: Keep Alive". A novel technique for allowing the reuse of server 
side connections in this specific, important case was described in detail in the 
commonly-owned, U.S. Patent Application No. 09/188,709, filed November 10, 

20 1 998, entitled, "Internet Client-Server Multiplexer". Interface unit 202 inspects 

the GET packet to detect this situation. When this case is detected, interface unit 
202 inserts "Connection: Keep-Alive" into the GET packet. Since this is done 
invisibly to the client, interface unit 202 must keep track of the number of "Bytes 
Added" on the server side connection. The "Bytes Added" does not affect the 

25 Sequence numbers in the GET packet since the sequence number is that of the 

first byte. However, interface unit 202 must add "Bytes Added" to the sequence 
number of subsequent packets from the client to the server. Conversely, the 
server will acknowledge the additional bytes, but interface unit 202 must subtract 
them before sending the acknowledgment to the client - which does not know that 

30 these bytes were added. 
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As mentioned above, connection multiplexing is achieved by 
manipulating sequence and acknowledgment numbers. Sequence and 
acknowledgment numbers of segments received by interface unit 202 are 
modified and mapped to values expected by the recipient. To the client, data 
appears to be coming from the server and vice versa. For example if "Inflow" 
denotes a segment received by interface unit 202 and "Outflow" denotes the 
corresponding outbound segment, the sequence and acknowledge numbers are 
changed in the following manner: 

Outflow sequence number = Inflow sequence number - Inflow 
starting sequence number + Outflow starting sequence number 

Outflow acknowledge number = Inflow acknowledge number - 
Inflow starting acknowledge number + Outflow starting 
acknowledge number 

To address the addition of the "Connection: Keep Alive" header for HTTP/1 .0 
packets, interface unit 202 keeps track of "Bytes Added" on the appropriate half 
of the connection - in this case the server side. The sequence number and 
acknowledgment number formulas are changed as follows: 

Outflow sequence number = Inflow sequence number - Inflow 
starting sequence number + Outflow starting sequence number + 
Outflow Bytes Added 

Outflow acknowledge number = Inflow acknowledge number - 
Inflow starting acknowledge number + Outflow starting 
acknowledge number - Inflow Bytes Added 
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Specific examples of translations accomplished using these equations 
while incorporating the content length parameter technique of the present 
invention to provide more efficient connection pooling is described below with 
reference to FIGs. 8 and 9 (relating to content length parameter) and FIGs. 1 0 and 
5 11 (relating to chunk-size fields). 

FIG. 8 is a detailed flow diagram illustrating the translations of 
acknowledgment and sequence numbers performed by the present invention 
while incorporating the content length parameter technique. The label for each 
flow in FIG. 8 is of the form T:S,A(L), where T represents a TCP segment type, 

10 S is the sequence number, A is the acknowledgment number, and L is the content 

length parameter. The content length parameter describes the number of bytes 
of data in the message. 

Flows 802A-802C present one method of opening the connection between 
client CI and interface unit 202. Each flow represents a TCP segment. In TCP 

15 segment 802A, the SYN flag in the TCP header is set, indicating a new 

connection request from client CI . Client CI has established a starting sequence 
number of 2000 and an acknowledgment number of 2000. Interface unit 202 
responds with a SYN ACK segment specifying a starting sequence number of 
4000, and incrementing the acknowledgment number to 2001 , as shown by flow 

20 802B. Each entity (e.g., client, server, interface unit) within the network sets its 

own unique sequence number and/or acknowledgment number, as is well known 
in the art. Client CI responds with an ACK segment specifying a sequence 
number of 2001 and incrementing the acknowledgment number to 4001, as 
shown by flow 802C. Client CI then sends a GET segment specifying a length 

25 of 49 bytes, as shown by flow 804. 

Assume that interface unit 202 determines that no free open connections 
exist with server S and therefore sends a SYN segment to server S, specifying a 
starting sequence number of 1 950, as shown in flow 806A. Server S responds 
with a SYN ACK segment specifying a starting sequence number of 6000 and 

30 incrementing the acknowledgment number to 1 95 1 , as shown in 806B . Interface 
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unit 202 responds with an ACK segment, as shown by flow 806C. Interface unit 
202 then forwards the GET segment from client CI to server S, after modifying 
the sequence and acknowledgment numbers according to the translation equations 
described above, as shown by flow line 808. 
5 Server S responds with the requested data specifying a sequence number 

of 600 1 , an acknowledgment number of 2000, and a content length parameter of 

999, as shown by flow 810. Interface unit 202 receives the RESP segment, 
translates the sequence and acknowledgment numbers, and forwards the RESP 
segment to client CI, as shown by flow line 812A. 

10 At this point, interface unit 202 receives a request by client C2 to open a 

connection. As above, flows 816A-816C present one method of opening the 
connection between client C2 and interface unit 202 . Again, each flow represents 
a TCP segment. In TCP segment 816A, the SYN flag in the TCP header is set, 
indicating a new connection request from client C2. Client C2 has established a 

15 starting sequence number of 999 and an acknowledgment number of 999. 

Interface unit 202 responds with a SYN ACK segment specifying a starting 
sequence number of 4999, and incrementing the acknowledgment number to 

1000, as shown by flow 816B. Client C2 responds with an ACK segment 
specifying a sequence number of 1000 and incrementing the acknowledgment 

20 number to 5000, as shown by flow 8 1 6C. Client C2 then sends a GET segment 

specifying a length of 50 bytes, as shown by flow 818. 

Assume at this point that interface unit 202 has no available connections 
to server S. The goal is to reuse the same connection to server S that was 
previous used for client CI if client CI is finished with the connection or is in 

25 "think time". Instead of waiting for client C 1 to initiate a FIN (finish) command 

or a RST (reset) command to free up the connection, interface unit 202 uses the 
content length parameter to confirm that all of the requested data has been 
received by client CI. Here, at flow 812B, interface unit 202 receives 
confirmation from client C 1 that client C 1 has in fact received all of the requested 

30 data. This indicates to interface unit 202 that, even though client CI may be 
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pausing for some reason before it sends a FIN or RST command, client CI is 
finished with the connection. Interface unit 202 modifies the acknowledgment 
and sequence numbers and forwards the RESP ACK segment to server S, as 
shown by flow812C. 

5 Using the same connection as used with client C 1 , interface unit 202 then 

forwards the GET segment from client C2 to server S, after modifying the 
sequence and acknowledgment numbers according to the translation equations 
described above, as shown by flow line 820. Server S responds with the 
requested data specifying a sequence number of 7000, an acknowledgment 

10 number of 2050, and a content length parameter of 500, as shown by flow 822. 

Interface unit 202 receives the RESP segment, translates the sequence 
and acknowledgment numbers, and forwards the RESP segment to client C2, as 
shown by flow line 824A. Here, at flow 824B, interface unit 202 gets 
confirmation from client C2 that client C2 has in fact received all of the requested 

1 5 data. Interface unit 202 modifies the acknowledgment and sequence numbers and 

forwards the RESP ACK segment to server S, as shown by flow 824C. 

The connection between client C2 and interface unit 202 is then closed or 
delinked once interface unit 202 receives a FIN or RST command from client C2, 
as shown by flows 826A-826D. Likewise, the connection between client CI and 

20 interface unit 202 is then closed or delinked once it receives a FIN or RST 

command from client C 1 , as shown by flows 8 1 4A-8 1 4D . It is important to note, 
however, that interface unit 202 maintains the connection with server S. It is also 
important to note that the sequence of events as they were described with 
reference to FIG. 8 is for illustration purposes only and does not limit the present 

25 invention. 

FIG. 9 is a flowchart depicting the operation of the use of the content 
length parameter to increase the efficiency of the pooling of connections between 
clients and servers according to an embodiment of the present invention. 
Interface unit 202 maintains connections with a plurality of servers, and routes 

30 client requests to these servers based on the path name specified in the client 
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request. First, interface unit 202 opens connections with the servers, as shown 
in step 902. Next, in response to a client CI request, interface unit 202 opens a 
connection to client CI and receives a request from client CI to retrieve data 
using a path name, as shown in step 904. 

Interface unit 202 then selects the server hosting the content specified by 
the path name, as shown in step 906. In alternative embodiments, interface unit 
202 consults other predefined policies to select the appropriate server, such as the 
load of the servers and the state of the servers. Interface unit 202 manages and 
maintains a database of servers and server farms that it tends. Among other 
things, information in this database includes currently active policies and rules 
that allow interface unit 202 to direct incoming packets to the correct server. 
Depending on network conditions and services desired, these policies and rules 
can change very quickly. 

Interface unit 202 then translates the request and passes the translated 
request to the selected server, as shown in step 908. Interface unit 202 receives 
the response from server S, as shown in step 910. Interface unit 202 then 
translates the response and passes the translated response on to client CI, as 
shown in step 912. 

Assume for illustration purposes that at this point interface unit 202 
receives a request from client C2 to retrieve data. Interface unit 202, in response 
to the client C2 request, opens a connection to client C2 and receives a request 
from client C2 to retrieve data using a path name, as shown in step 914. Interface 
unit 202 then selects the server hosting the content specified by the path name, 
as shown in step 916. 

In step 918, interface unit 202 determines whether client C2 has selected 
the same server as client CI. If the outcome to step 918 is negative, then 
interface unit 202 proceeds in a fashion necessary to satisfy client C2's request 
(which is not important to the present invention). At this point the flowchart in 
FIG. 9 ends. Alternatively, if the outcome to step 918 is positive, then interface 
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unit 202 determines whether there are any open connections to the selected 
server, as shown in step 920. 

If the outcome to step 920 is positive, then interface unit 202 proceeds in 
a fashion necessary to satisfy client C2's request (which is not important to the 
present invention). At this point the flowchart in FIG. 9 ends. Alternatively, if 
the outcome to step 920 is negative, then interface unit 202 utilizes the content 
length parameter to confirm that client CI received all of the data that client CI 
requested, as shown in step 922. It is important to note that interface unit 202 
does not wait for client CI to send a FIN or RST command in order to determine 
that client CI is finished with the connection or is in "think time". This allows 
for more efficient connection pooling due to the fact that interface unit 202 can 
utilize each connection quicker than if interface unit 202 waited for the client to 
close the connection prior to reusing the connection for another client. 

In step 924, interface unit 202 then translates the request and passes the 
translated request to the selected server using the same connection as client CI 
used, as shown in step 924. Interface unit 202 receives the response from server 
S, as shown in step 926. Interface unit 202 then translates the response and 
passes the translated response on to client C2, as shown in step 928. Interface 
unit 202 utilizes the content length parameter to confirm that client C2 received 
all of the data that client C2 requested, as shown in step 930. 

Next, interface unit 202 closes or delinks the connection with client C2 
in step 932. Finally, interface unit 202 closes or delinks the connection with 
client CI in step 934, and the flowchart in FIG. 9 ends. As stated above with 
reference to FIG. 8, the sequence of events as they were described with reference 
to FIG. 9 is for illustration purposes only and does not limit the present invention. 

FIG. 10 is a detailed flow diagram illustrating the translations of 
acknowledgment and sequence numbers performed by the present invention 
while incorporating the chunk-size fields technique. The label for each flow in 
FIG. 10 is of the form T:S,A(L), where T represents a TCP segment type, S is the 
sequence number, A is the acknowledgment number, and L is a chunk-size field. 
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The total values of the chunk-size fields describes the number of bytes of data in 
the TCP segment. 

For simplicity, we assume that connections to both client CI and client 
C2 have already been established. Client CI then sends a GET segment 
specifying a length of 49 bytes, as shown by flow 1002. Interface unit 202 
determines that no free open connections exist with server S and therefore opens 
a connection with server S (not shown in FIG. 10). Interface unit 202 then 
forwards the GET segment from client CI to server S, after modifying the 
sequence and acknowledgment numbers according to the translation equations 
described above, as shown by flow line 1004. 

For illustration purposes, assume that the data in the response segment has 
a total content data length of 999. Further assume that the data will be 
transmitted in two 300 data chunks and one 399 data chunk. Note that this is for 
illustration purposes only and is not intended to limit the present invention. 
Therefore, the server S first responds with a chunk of the requested data (or 
message) specifying a sequence number of 6001 , an acknowledgment number of 
2000, and a chunk-size field of 300, as shown by flow 1 008A. Interface unit 202 
receives the RESP segment, translates the sequence and acknowledgment 
numbers, and forwards the RESP segment to client CI, as shown by flow line 
1006 A. Client CI acknowledges receipt of the data to interface unit 202, as 
shown by flow line 1006B. Interface unit 202 in return passes this 
acknowledgment on to server S, as shown by flow line 1008B. 

Server S next responds with the second chunk of the requested data 
specifying a sequence number of 63 0 1 , an acknowledgment number of 200 1 , and 
a chunk -size field of 300, as shown by flow 1012A. Interface unit 202 receives 
the RESP segment, translates the sequence and acknowledgment numbers, and 
forwards the RESP segment to client CI, as shown by flow line 101 OA. Client 
CI acknowledges receipt of the data to interface unit 202, as shown by flow line 
101 0B. Interface unit 202 in return passes this acknowledgment on to server S, 
as shown by flow line 101 2B. 
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Server S next responds with the third chunk of the requested data 
specifying a sequence number of 660 1 , an acknowledgment number of 2002, and 
a chunk-size field of 399, as shown by flow 1016A. Interface unit 202 receives 
the RESP segment, translates the sequence and acknowledgment numbers, and 
5 forwards the RESP segment to client CI, as shown by flow line 1014A. Client 

CI acknowledges receipt of the data to interface unit 202, as shown by flow line 
1014B. Interface unit 202 in return passes this acknowledgment on to server S, 
as shown by flow line 1016B. 

Finally, server S responds with the final chunk of the zero data (indicated 

10 by a chunk-size field that equals zero) specifying a sequence number of 7000, an 

acknowledgment number of 2003, and a chunk-size field of 0, as shown by flow 
1 020. Interface unit 202 receives the RESP segment, translates the sequence and 
acknowledgment numbers, and forwards the RESP segment to client CI, as 
shown by flow line 1 0 1 8 . This indicates to interface unit 202 and client C 1 that 

15 all of the requested data has been transmitted. 

At this point, client C2 then sends a GET segment specifying a length of 
5 0 bytes, as shown by flow 1 022. Assume at this point that interface unit 202 has 
no available connections to server S. The goal is to reuse the same connection 
to server S that was previous used for client CI if client CI is finished with the 

20 connection or is in "think time". Instead of waiting for client C 1 to initiate a FIN 

(finish) command or a RST (reset) command to free up the connection, the 
interface unit uses the chunk-size field that equaled zero to confirm that all of the 
requested data has been received by client CI. This indicates to interface unit 
202 that, even though client CI may be pausing for some reason before it sends 

25 a FIN or RST command, client C 1 is finished with the connection. Interface unit 

202 modifies the acknowledgment and sequence numbers and forwards the GET 
segment to server S, as shown by flow 1024. 

For illustration purposes, assume that the data in the response segment has 
a total content data length of 500. Further assume that the data will be 

30 transmitted in one 300 data chunk and one 200 data chunk. Note that this is for 
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illustration purposes only and is not intended to limit the present invention. 
Therefore, the server S first responds with a chunk of the requested data 
specifying a sequence number of 7000, an acknowledgment number of 2050, and 
a chunk-size field of 300, as shown by flow 1028A. Interface unit 202 receives 
5 the RESP segment, translates the sequence and acknowledgment numbers, and 

forwards the RESP segment to client C2, as shown by flow line 1026 A. Client 
C2 acknowledges receipt of the data to interface unit 202, as shown by flow line 
1 026B. Interface unit 202 in return passes this acknowledgment on to server S, 
as shown by flow line 1028B. 

10 Server S next responds with the second chunk of the requested data 

specifying a sequence number of 73 00, an acknowledgment number of 205 1 , and 
a chunk-size field of 200, as shown by flow 1032A. Interface unit 202 receives 
the RESP segment, translates the sequence and acknowledgment numbers, and 
forwards the RESP segment to client C2, as shown by flow line 103 OA. Client 

15 C2 acknowledges receipt of the data to interface unit 202, as shown by flow line 

103 0B. Interface unit 202 in return passes this information on to server S, as 
shown by flow line 1032B. 

Finally, server S responds with the final chunk of the zero data (indicated 
by a chunk-size field that equals zero) specifying a sequence number of 7500, an 

20 acknowledgment number of 2052, and a chunk-size field of 0, as shown by flow 

1036. Interface unit 202 receives the RESP segment, translates the sequence and 
acknowledgment numbers, and forwards the RESP segment to client C2, as 
shown by flow line 1034. This indicates to interface unit 202 and client C2 that 
all of the requested data has been transmitted. 

25 The connection between client C2 and interface unit 202 is then closed or 

delinked once interface unit 202 receives aFTN or RST command from client C2, 
as shown by flow 1038. Likewise, the connection between client CI and 
interface unit 202 is then closed or delinked once it receives a FIN or RST 
command from client CI, as shown by flow 1040. It is important to note, 

30 however, that interface unit 202 maintains the connection with server S. It is also 
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important to note that the sequence of events as they were described with 
reference to FIG. 10 is for illustration purposes only and does not limit the 
present invention. 

FIG. 1 1 is a flowchart depicting the operation of the use of the chunk-size 
5 fields to increase the efficiency of the pooling of connections between clients and 

servers according to an embodiment of the present invention. Interface unit 202 
maintains connections with a plurality of servers, and routes client requests to 
these servers based on the path name specified in the client request. First, 
interface unit 202 opens connections with the servers, as shown in step 1102. 

10 Next, in response to a client C 1 request, interface unit 202 opens a connection to 

client C 1 and receives a request from client C 1 to retrieve data using a path name, 
as shown in step 1 104. 

Interface unit 202 then selects the server hosting the content specified by 
the path name, as shown in step 1106. Interface unit 202 then translates the 

15 request and passes the translated request to the selected server, as shown in step 

1 108. Interface unit 202 receives the response from server S, as shown in step 
1110. Interface unit 202 then translates the response and passes the translated 
response on to client CI until chunk-size field is equal to zero, as shown in step 
1112. 

20 Assume for illustration purposes that at this point interface unit 202 

receives a request from client C2 to open a connection. Interface unit 202, in 
response to a client C2 request, opens a connection to client C2 and receives a 
request from client C2 to retrieve data using a path name, as shown in step 1114. 
Interface unit 202 then selects the server hosting the content specified by the path 

25 name, as shown in step 1116. 

In step 1118, interface unit 202 determines whether client C2 has selected 
the same server as client CI. If the outcome to step 1118 is negative, then 
interface unit 202 proceeds in a fashion necessary to satisfy client C2's request 
(which is not important to the present invention). At this point the flowchart in 

30 FIG. 11 ends. Alternatively, if the outcome to step 1118 is positive, then 
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interface unit 202 determines whether there are any open connections to the 
selected server, as shown in step 1 120. 

If the outcome to step 1 120 is positive, then interface unit 202 proceeds 
in a fashion necessary to satisfy client C2's request (which is not important to the 
present invention). At this point the flowchart in FIG. 11 ends. Alternatively, if 
the outcome to step 1 120 is negative, then interface unit 202 utilizes the fact that 
chunk-size field equaled zero in step 1 1 12 to confirm that client CI received all 
of the message data that client C 1 requested. It is important to note that interface 
unit 202 does not wait for client CI to send a FIN or RST command in order to 
determine that client CI is finished with the connection or is in "think time". 

In step 1 122, interface unit 202 then translates the request and passes the 
translated request to the selected server using the same connection as client CI 
used. Interface unit 202 receives the response from server S, as shown in step 
1 124. Interface unit 202 then translates the response and passes the translated 
response on to client C2 until chunk-size field equals zero, as shown in step 1 1 26. 
Interface unit 202 utilizes the chunk-size field to confirm that client C2 received 
all of the message data that client C2 requested. 

Next, interface unit 202 closes or delinks the connection with client C2 
in step 1 128. Finally, interface unit 202 closes or delinks the connection with 
client CI in step 1 130, and the flowchart in FIG. 1 1 ends. As stated above with 
reference to FIG. 10, the sequence of events as they were described with 
reference to FIG. 1 1 is for illustration purposes only and does not limit the 
present invention. 

The present invention may be implemented using hardware, software or 
a combination thereof and may be implemented in a computer system or other 
processing system. In fact, in one embodiment, the invention is directed toward 
one or more computer systems capable of carrying out the functionality described 
herein. An example computer system 1200 is shown in FIG. 12. The computer 
system 1200 includes one or more processors, such as processor 1204. The 
processor 1204 is connected to a communication bus 1206. Various software 
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embodiments are described in terms of this example computer system. After 
reading this description, it will become apparent to a person skilled in the relevant 
art how to implement the invention using other computer systems and/or 
computer architectures. 

Computer system 1200 also includes a main memory 1208, preferably 
random access memory (RAM), and can also include a secondary memory 1210. 
The secondary memory 1210 can include, for example, a hard disk drive 1212 
and/or a removable storage drive 1214, representing a floppy disk drive, a 
magnetic tape drive, an optical disk drive, etc. The removable storage drive 
1214 reads from and/or writes to a removable storage unit 1218 in a well known 
manner. Removable storage unit 121 8, represents a floppy disk, magnetic tape, 
optical disk, etc. which is read by and written to by removable storage drive 1214. 
As will be appreciated, the removable storage unit 1218 includes a computer 
usable storage medium having stored therein computer software and/or data. 

In alternative embodiments, secondary memory 1210 may include other 
similar means for allowing computer programs or other instructions to be loaded 
into computer system 1200. Such means can include, for example, a removable 
storage unit 1 222 and an interface 1 220. Examples of such can include a program 
cartridge and cartridge interface (such as that found in video game devices), a 
removable memory chip (such as an EPROM, or PROM) and associated socket, 
and other removable storage units 1 222 and interfaces 1 220 which allow software 
and data to be transferred from the removable storage unit 1218 to computer 
system 1200. 

Computer system 1200 can also include a communications interface 1224. 
Communications interface 1224 allows software and data to be transferred 
between computer system 1200 and external devices. Examples of 
communications interface 1 224 can include a modem, a network interface (such 
as an Ethernet card), a communications port, a PCMCIA slot and card, etc. 
Software and data transferred via communications interface 1224 are in the form 
of signals which can be electronic, electromagnetic, optical or other signals 



1763.0110000 



-28- 



capable of being received by communications interface 1224. These signals 1226 
are provided to communications interface via a channel 1228. This channel 1228 
carries signals 1226 and can be implemented using wire or cable, fiber optics, a 
phone line, a cellular phone link, an RF link and other communications channels. 

In this document, the terms "computer program medium" and "computer 
usable medium" are used to generally refer to media such as removable storage 
device 1218, a hard disk installed in hard disk drive 1212, and signals 1226. 
These computer program products are means for providing software to computer 
system 1200. 

Computer programs (also called computer control logic) are stored in 
main memory and/or secondary memory 1210. Computer programs can also be 
received via communications interface 1224. Such computer programs, when 
executed, enable the computer system 1200 to perform the features of the present 
invention as discussed herein. In particular, the computer programs, when 
executed, enable the processor 1204 to perform the features of the present 
invention. Accordingly, such computer programs represent controllers of the 
computer system 1200. 

In an embodiment where the invention is implemented using software, the 
software may be stored in a computer program product and loaded into computer 
system 1200 using removable storage drive 1214, hard drive 1212 or 
communications interface 1224. The control logic (software), when executed by 
the processor 1204, causes the processor 1204 to perform the functions of the 
invention as described herein. 

In another embodiment, the invention is implemented primarily in 
hardware using, for example, hardware components such as application specific 
integrated circuits (ASICs). Implementation of the hardware state machine so as 
to perform the functions described herein will be apparent to persons skilled in 
the relevant art(s). In yet another embodiment, the invention is implemented 
using a combination of both hardware and software. 
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The present invention is described specifically when implemented within 
an interface unit, such as interface unit 202, that is connected to servers in a farm 
for the purpose of offloading connection processing overhead from the servers. 
However, the present invention can also be applied within other kinds of devices 
that are in the network connection path between the client and the servers. As 
network traffic flows through such devices, they all have the opportunity to apply 
the present invention to offload connection processing. Some examples of such 
devices are: 

- Load Balancers which distribute client network connections between a 
set of servers in a server farm (local or geographically distributed). The invention 
can readily be combined with the load balancing function. 

- Bandwidth managers which monitor network traffic and meter packet 
flow. These devices can also use the present invention. 

- Firewalls monitor packets and allow only the authorized packets to flow 
through. The present invention can be used to provide an additional feature 
within firewalls. 

- Routers and switches also lie in the path of the network traffic. The 
industry trend is to integrate additional functionality (such as load balancing, 
bandwidth management and firewall functionality) within these devices. Hence, 
the present invention can easily be incorporated into a router. 

The specific integration of the present invention into each one of the 
above devices is implementation specific. 

The present invention can also be applied within computer systems which 
are the end points of network connections. In this case, add-on cards can be used 
to implement the invention and thus offload the main processing elements within 
the computer system. 

Conclusion 

The previous description of the preferred embodiments is provided to 
enable any person skilled in the art to make or use the present invention. The 
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various modifications to these embodiments will be readily apparent to those 
skilled in the art, and the generic principles defined herein may be applied to 
other embodiments without the use of the inventive faculty. Thus, the present 
invention is not intended to be limited to the embodiments shown herein but is 
to be accorded the widest scope consistent with the principles and novel features 
disclosed herein. 
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What Is Claimed Is: 

1 1 . An apparatus comprising: 

2 means for opening a connection between a first client and an 

3 interface unit; 

4 means for opening a connection between said interface unit and 

5 a server if no free connection is open between said interface unit and said server; 

6 means for allowing said first client to access information on said 

7 server via said connection; 

8 means for opening a connection between a second client and said 

9 interface unit; and 

10 means for allowing said second client to access information on 

1 1 said server via said connection by determining as soon as said first client is 

1 2 finished with said connection without waiting for said first client to initiate said 

1 3 first client is finished with said connection. 

1 2. The apparatus of claim 1 , further comprising: 

2 means for delinking said connection between said first and second 

3 clients and said interface unit while keeping open said connection between said 

4 interface unit and said server. 

1 3. The apparatus of claim 1, wherein determining when said first 

2 client is finished with said connection is comprised of: 

3 means for utilizing a content length parameter to determine 

4 whether all of said information has been sent to said first client. 

1 4. The apparatus of claim 1, wherein determining when said first 

2 client is finished with said connection is comprised of: 

3 means for utilizing two or more chunk-size fields to determine 

4 whether all of said information has been sent to said first client. 
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1 5. A method comprising the steps of: 

2 opening a connection between a first client and an interface unit; 

3 opening a connection between said interface unit and a server if 

4 no free connection is open between said interface unit and said server; 

5 allowing said first client to access information on said server via 

6 said connection; 

7 opening a connection between a second client and said interface 

8 unit; and 

9 allowing said second client to access information on said server 

1 0 via said connection by determining as soon as said first client is finished with said 

1 1 connection without waiting for said first client to initiate said first client is 

12 finished with said connection. 

1 6. The method of claim 5, further comprising the step of: 

2 delinking said connection between said first and second clients and 

3 said interface unit while keeping open said connection between said interface unit 

4 and said server. 

1 7. The method of claim 5, wherein said determining when said first 

2 client is finished with said connection is comprised of the step of: 

3 utilizing a content length parameter to determine whether all of 

4 said information has been sent to said first client. 

1 8. The method of claim 5, wherein said determining when said first 

2 client is finished with said connection is comprised of the step of: 

3 utilizing two or more chunk-size fields to determine whether all 

4 of said information has been sent to said first client. 
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Apparatus, Method and Computer Program 
Product for Efficiently Pooling Connections 
Between Clients and Servers 

Abstract 

An apparatus, method and computer program product for efficiently 
pooling network client-server connections. The apparatus is implemented within 
an interface unit connecting a plurality of servers to the Internet, which is in turn 
connected to a plurality of clients. The method includes the steps of opening a 
connection between a first client and the interface unit; determining whether a 
connection between the interface unit and a server is finished being utilized by 
the first client; opening a connection between a second client and the interface 
unit; if no free connection is open between the interface unit and the server, then 
allowing the second client to access information on the server via the same 
connection utilized by the first client without waiting for the first client to initiate 
closing the connection; and delinking the connections between the first and 
second clients and the interface unit while keeping open the connection between 
the interface unit and the server. 

P:\USERS\MAMCALL\Projects\Projects_1763\1763.0110000\A278-91.wpd 
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